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-ABSTRACT- 

“Yhis  document  i*  a  proposal  for  a  distributed  data  base 
management  system  (DDBMS).  It  represents  the  first  phase  of 
the  DDBMS  design  portion  of  Grant  108.  It  is  very  important 
to  note  that  this  document  is  a  proposal  and  also  that  the 
next  phase  of  the  design  is  the  development  of  the 
functional  specifications  of  the  DDBMS.  Therefore,  it  is 
essential  that  all  interested  parties  respond  with  any 
corrections,  additions,  deletions,  suggestions,  etc.  by  July 
1,  1976. 

As  it  can  easily  be  observed  from  this  report,  the 
implementation  of  the  complete  DDBMS  will  be  an  enormous 
task.  Estimates  range  from  7  to  20  up  to  SO  person  years  of 
effort.  A  natural  course  is  to  design  a  full  scale  system 
and  proceed  with  the  implementation  in  an  incremental 
manner.  The  implementation  of  a  minimal  prototype  should  be 
achieved  as  soon  as  possible  for  purposes  of  feasibility 
studies,  testing,  and  morale.**.  Another  important 
consideration  is  that  based  upoh'  \he  current  resource 
allocation  to  the  data  base  portions  of  Grant  108,  it  is 
unlikely  that  the  Special  Features  described  in  Chapter  VIII 
can  be  included  in  the  initial  ODBMS  design. 
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PREFACE 

This  document  is  a  proposal  for  a  distributed  data  base  management 
system  (DDBMS).  It  represents  the  first  phase  of  the  DDBMS  design  portion 
of  Grant  108.  It  is  very  important  to  note  that  this  document  is  a  proposal 
and  also  that  the  next  phase  of  the  design  is  the  development  of  the  func¬ 
tional  specifications  of  the  DDBMS.  Therefore,  it  is  essential  that  all 
interested  parties  respond  with  any  corrections,  additions,  deletions, 
suggestion,  etc.  by  July  1,  1976. 

As  it  can  easily  be  observed  from  this  report,  the  implementation  of 
tne  complete  DDBMS  will  be  an  enormous  task.  Estimates  range  from  7  to  20 
up  to  50  person  years  of  effort.  A  natural  course  is  to  design  a  full 
scale  system  and  proceed  with  the  implementation  in  an  incremental  manner. 

The  implementation  of  a  minimal  prototype  should  be  achieved  as  soon  as 
possible  for  purposes  of  feasibility  studies,  testing,  and  morale.  Another 
important  consideration  is  thut  based  upon  the  current  resource  allocation 
to  the  data  base  portion  of  Grant  108,  it  is  unlikely  that  the  Special  Features 
described  in  Chapter  VIII  can  be  included  in  the  initial  DDBMS  design. 

Again,  any  inputs  regarding  the  specification  design  or  implementation 
•..'ill  be  greatly  appreciated. 


ABSTRACT 


This  report  describes  the  features  of  a  proposed  distributed  data  base 
management  system  (DDBMS) .  DDBMS  is  based  upon  the  CODASYL  specifications. 

It  is  intended  for  use  in  a  multi-computer  environment  in  which  many  of  the 
machines  will  be  mini-computers  produced  by  different  vendors.  This  document 
concentrates  on  the  user  level  view  of  the  system.  That  is,  the  features 
of  the  DDBMS  are  presented,  rather  than  the  functional  specification.  The 
main  areas  of  emphasis  are  the  schema  data  definition  language,  sub-schema 
data  definition  language,  data  manipulation  language,  device  media  control 
language,  and  utility  routines.  Some  further  enhancements  of  DDBMS  arc 
suggested  and  a  comparison  is  made  with  existing  CODASYL-based  DBMS  systems. 
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Introduction 

In  this  report,  a  set  of  specifications  are  presented  for  s  distributed 
data  base  management  system  (DDE MS) .  The  DDBMS  is  based  upon  the  CODASYb 
specifications  [1].  The  DDBMS  is  targeted  for  a  network  environment.  The 
machines  comprising  the  network  may  be  of  various  types  and  sizes.  In 
DDBMS,  a  user  may  initiate  a  program  from  any  computer  in  the  network,  have 
it  executed  on  another  (or  the  same’  processor)  and  access  data  on  storage 
devices  at  any  node  in  the  network  (provided  security  restrictions  are 
satisfied).  A  discussion  of. the  characteristics  of  distributed  data  base 
systems  is  given  in  Reference  [2],  The  communication  system  for  the  network 
is  described  in  Reference  [3]. 

This  document  presents  the  application  programmer  view  of  the  DDBMS. 

The  physical  structure  of  the  system  is  transparent  to  the  user.  The  appli¬ 
cation  programmer  need  only  to  concern  herself/himself  with  the  language 
features  as  listed  in  this  report.  The  languages  of  the  DDBMS  are  identical 
in  both  network  and  single  machine  environments.  Implementation  considerations 
are  treated  in  Reference  [A]. 

The  essential  concepts  of  data  base  management  systems  are  initially  dis¬ 
cussed  to  form  a  basis  for  the  language  definitions. .  The  DDBMS  contains  four  lan¬ 
guages:  a  schema  data  definition  language  to  describe  the  structure  of  an  entire 
data  base:  a  subschema  data  definition  language  to  select  the  portion  of  the  data 
base  visible  to  an  application  program;  a  data  manipulation  language  to  oper¬ 
ate  on  a  data  base;  and  a  device  media  control  language  to  map  the  logical 
data  base  onto  physical  storage.  The  syntax  of  each  of  the  four  languages  is 
specified  in  this  report  along  with  their  functional  characteristics. 

In  order  to  facilitate  the  use  of  DDBMS  by  a  wide  band  of  users  ranging 
from  clerical  personnel  to  the  data  base  administrator,  a  substantial  number 
of  utility  programs  have  been  included  in  the  system.  The  capabilities  of  the 
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DDBMS  utilities  are  listed  in  Chapter  VII  of  this  report. 

Chapter  VIII  presents  a  list  of  special  features  to  be  added  to  future 
versions  of  DDBMS.  These  enhancements  include  query  and  data  base  administrator 
languages,  a  debugging  facility,  a  report  generator,  a  data  dictionary  facility, 
and  an  interactive  data  base  design  language.  An  additional  topic  treated  in 
this  report  is  the  compatibility  of  DDBMS  and  relational  data  models.  Features 
have  been  included  in  DDBMS  with  the  intention  of  constructing  a  means  of  bridg¬ 
ing  the  differences  between  DDBKS  and  relational  data  bases  at  some  later  time. 

The  final  chapter  of  the  report  concentrates  on  the  differences  between 
DDBMS  the  CODASYL  specifications  [1],  and  four  existing  CODASYL  based  DBMS 
packages,  DEC'S  DBMS-10,  UNIVAC's  DMS-1100,  Honeywell's  (Xerox)  EDMS,  and 
Cullinane's  IDMS.  The  comparison  shows  that  DDBMS’  is  the  closest  system  to 
the  original  CODASYL  specifications. 

II.  DBMS  Concepts 

A.  Definitions 

Schema  -  complete  description  of  a  data  base. 

Sub-Schema  -  description  of  data  base  known  to  a  particular 
program. 

Schema  DDL  -  Language  for  describing  a  data  base. 

Sub-Schema  DDL  -  Language  for  describing  that  part  of  a  data 
base  known  to  a  program. 

DML  -  Language  used  by  the  programmer  to  cause  data  to  be 
transferred  by  the  program  to  the  data  base. 

Data-Item  -  smallest  unit  of  named  data. 

Data- Aggregate  -  collection  of  data-items  ;  either  vector  or 
repeating  group. 

Record  -  collection  of  data-items  or  data-aggregates .  There 
may  be  an  arbitrary  number  of  occurrences  of  a  given  record  type 


in  a  data  base. 
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9.  Set  -  collection  of  record  types. 

10.  Realm  -  sub-division  of  addressable  secondary  storage  space. 

11.  Data  base  -  record  occurrences,  set  occurrences,  and  realms 
controlled  by  a  specific  schema. 

12.  Data  Base  Key  -  unique  name  assigned  to  each  record  occurrence. 
Used  to  map  to  the  physical  location  of  the  record. 

B.  Implementation  Considerations  * 

The  DDL's  and  the  DML  are  all  COBOL  based  languages.  The  DDL's  are 
distinct  languages  which  strongly  resemble  COBOL  Data  Division  statements. 
Separate  compilers  are  required  for  the  schema  and  sub— schema  DDL.  These 
compilers  produce  object  versions  of  the  schema  and  sub-schema  which  are 
essentially  templates  which  define  the  layout  and  logical  organization 
of  the  data  base. 

The  DML  is  actually  an  extension  of  COBOL  to  facilitate  accessing  of  the 
data  base.  A  pre-processor  can  be  used  to  map  the  DML  statements  into  standard 
COBOL  for  processing  by  the  COBOL  compiler. 

The  organization  of  a  CODASYL  DBMS  is  depicted  in  Figure  1.  The  actions 
resulting  from  a  user  data  manipulation  language  (DML)  command  are  discussed 
below  as  a  means  of  illustrating  the  workings  of  the  system. 

1.  A  DML  command  is  encountered  in  the  application  program.  A  call  to 
the  DBMS  is  then  issued. 

2.  The  DBMS  analyzes  the  call  and  verifies  the  request  against  the  object 
versions  of  the  schema  and  sub-schema. 

3.  The  contents  of  system  buffers  are  checked. 

4.  If  necessary,  the  DBMS  requests  that  the  operating  system  perform  a 
physical  I/O  transfer. 

5.  The  operating  system  controls  the  I/O  operation  of  6. 

6.  Data  is  transferred  between  secondary  storage  and  system  buffers  by 
the  operating  system. 
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7.  The  DBMS  transfers  data  between  system  buffers  and  the  User  Working 
Area  (UWA)  as  required. 

8.  The  DBMS  provides  status  information  on  the  recently  completed 
operation. 

9.  The  data  in  the  UWA  may  be  operated  upon  in  any  manner  by  the  appli¬ 
cation  program. 

The  operation  of  a  DBMS  distributed  over  several  machines  is  not  described 
explicitly  in  this  report  since  the  report  is  concerned  with  the  user  level  spec¬ 
ifications  of  the  DBMS.  At  the  user  level  the  means  of  implementation  of  the  DBMS 

» 

in  terms  of  the  machine  configuration  is  transparent.  For  a  discussion  of  the 
basic  features  of  distributed  data  bases  see  Reference  [2], 

C.  Differences  Between  Schema  and  Sub-Schema 

As  previously  stated  a  schema  is  a  description  of  a  universal  data  base, 
while  a  sub-schema  is  the  user's  view  of  the  data  base.  Since  the  sub-schemata 
available  to  the  individual  user  are  determined  by  the  data  base  administrator 
(whose  function  is  discussed  in  Section  II, E),  the  concept  of  a  sub-schema 
entails  intrinsic  security  mechanisms. 

In  DDBMS,  a  sub-schema  is  for  the  most  part  a  subset  of  the  schema.  Realms, 
aets,  and  records  may  be  copied  in  toto  from  the  schema.  At  any  level,  lower 
level  entities  may  be  emitted.  For  example,  sets  may  be  omitted  from  realms, 
records  from  sets,  etc.  The  only  other  differences  between  a  sub-schema  and 
it6  corresponding  schema  are  that  data  aggregates  may  be  formed  or  redefined 
at  the  record  level  provided  that  the  data  items  are  not  reordered^  and  that  names 
may  be  changed. 

D,  User  Working  Area 

Each  application  program  has  a  unique  UWA  which  serves  as  a  common  data 
area  shared  by  the  program  and  the  DBMS.  The  UWA  is  used  in  the  transfer  of 
data  between  the  program  and  the  data  base.  The  form  of  the  data  in  the  UWA 
is  derived  from  the  sub-schema.  During  execution,  the  UWA  holds  the  current 


(most  recently  accessed)  data  for  ell  set  and  record  types  defined  by  the 
sub-schema,  as  well  as  necessary  status  information. 

E.  The  Data  Base  Administrator 

In  any  system  as  complex  and  important  as  a  DBMS,  there  must  be  a 
clearly  defined  position  of  responsibility  to  oversee  its  operation.  The 
Data  Base  Administrator  (DBA)  is  responsible  for  the  organization,  monitoring, 
and  reorganization  of  the  data  base.'  The  IMA  defines  the  schema  of  the'data 
base  and  controls  access  to  it  through  the  definition  of  sub-schemata  for 
individual  applications.  Many  of  the  utility  functions  mentioned  in  the 
Chapter  VII  are  intended  for  usage  of  the  DBA.  A  list  of  the  principal 
DBA  functions  is  provided  below. 

1.  Model  the  data  base  using  the  Schema  DDL. 

2.  Assign  privacy  locks  and  keys. 

3.  Assign  realms  to  devices  by  specifying  the  DMCL  (see  Chapter  VI) . 

4.  Load  the  data  base. 

5.  Specify  the  sub-schema  DDL  for  an  application. 

6.  Assign  privacy  keyr  *o  application  programs. 

7.  Monitor  data  base  performance  and  security. 

8.  Modify  the  schema. 

9.  Supervise  data  migration  and  archiving. 

10.  Restructure  the  data  base. 

11.  Perform  garbage  collection. 

12.  Reassign  realms. 

13.  Tune  the  data  base  by  reorganizing  the  placement  of  data  in  order 
to  increase  system  performance. 

?.  Privacy 

It  is  proposed  that  DDBMS  implement  an  extensive  range  of  privacy  features. 


The  basic  security  mechanism  is- through  privacy  locks  which  are  specified  in 
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thc  schema  and  sub-schema,  and  privacy  keys  which  must  be  provided 
by  Che  application  program  to  access  daca  which  have  privacy  locks  assigned. 
Privacy  locks  can  be  assigned  ae  all  levels  of  the  schema  and  sub-schema. 

Locks  can  be  assigned  for  the  following  specific  functions. 

.  1.  At  the  schema  or  sub-schema  level,  locks  may  be  specified  against 

the  alteration  or  display  of  the  schema  or  sub-schema  itself, 
against  the  display  of  the'  locks,  or  against  the  use  of  the  sub¬ 
schema. 

2.  At  the  realm  level, flocks  may  be  specified  against  the  use  of  the 
realm  for  retrieval,  update,  or  any  support  function. 

3.  At  the  record  level,  locks  may  be  provided  against  the  use  of  each 
DHL  record,  data-item,  or  data-aggregate  command. 

4.  At  the  set  level,  locks  may  be  specified  against  each  DHL  set  operation. 

A  privacy  lock  is  a  single  value  against  which  the  application  program¬ 
generated  privacy  key  is  matched.  If  the  lock  and  key  match,  operation 
continues.  Otherwise,  a  DBA-supplied  routine  is  called  to  determine  the  action 
to  be  taken.  Depending  upon  the  potential  severity  of  the  intrusion,  this 
routine  may  pursue  a  course  of  action  ranging  from  merely  logging  the  unsuccessful 
match  to  suspending  execution  of  the  application  program  and  sending  a  message 

to  the  system  console. 

G.  Data  Integrity 

Since  sub-schemata  may  overlap  it  is  possible  that  different  applications 
programs  may  interact  with  the  same  data  concurrently.  This  situation  can 
arise  when  the  DBMS  is  executing  under  any  operating  system  that  allows  multi¬ 
tasking.  Facilities  exist  within  the  DML  to  allow  an  application  program 
to  be  notified  when  concurrent  updating  of  a  record  occurrence  is  taking  place. 

The  USAGE  MODE  feature  allows  a  program  to  establish  exclusive  control 
over  a  realm.  When  data  is  shared,  it  is  possible  for  two  or  more  programs 


to  enter  a  deadlock  state  when  simultaneously  attempting  to  access  shared 

data  items.  In  DDBMS,  a  deadlock  prevention  algorithm  is  employed  to  insure 

proper  data  access  at  the  record  level.  Basically,  deadlock  Is  avoided  by 

allowing  the  system  to  give  exclusive  control  over  a  set  of  records  to  a 

program  that  accesses  shared  data  items.  This  exclusive  control  of  records 
« 

is  transparent  to  the  user  and  beyond  program  control.  In  order  to  properly 
maintain  lists  of  shared  records,  some  amount  of  intertask  communication  is 
necessary.  However,  this  communications  overhead  is  substantially  less  than 
that  accrued  if  a  deadlock  detection  scheme  were  used.  A  deadlock  detection 
algorithm  involves  rolling  back  tasks  to  some  deadlock-free  state.  Rollback 
of  comnunicating  tasks  in  a  network  environment  has  the  potential  for  a 
substantial  amount  of  communications  overhead  and  also  may  effect  tasks  not 
directly  involved  in  the  deadlock  situation.  For  more  information  concerning 
the  deadlock  problem  in  the  DDBMS  see  Reference  [5]. 

H.  Records 

I.  Data  types  -  DDBMS  supports  the  following  data  types. 

a.  Arithmetic  -  decimal  or  binary  base,  fixed  or  floating-point 
scale,  real  or  complex  mode. 

b.  String  -  character  or  bit  string. 

c.  Data  base  keys. 

d.  Vectors  -  one  dimensional,  ordered  collection  of  data  items. 

e.  Repeating  groups  -  collection  of  data  that  appears  an  arbitrary 
number  of  times. 

2.  Records  in  Sub-Schomata 

The  content  of  a  record  in  a  sub-schema  must  be  a  subset  of  the  corre¬ 
sponding  record  in  the  schema.  Records  are  defined  using  COBOL  Data  Division- 
type  statements.  Level  numbers  are  used  to  show  the  structure  within  the 
records.  Arrays  may  have  up  to  three  dimensions. 
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Each  data  Item  in  a  sub-schema  record  must  correspond  to  a  data 
item  or  aggregate  of  that  record  In  a  schema  or  be  a  new  group  whose 
subordinate  items  correspond  to  data  described  for  the  record  in  the 
schema.  Rules  for  correspondence  between  data-ltems  and  data  aggregates 
in  schema  and  sub-schema  records  are  given  below. 

a.  Data  items  in  the  schema  may  only  be  declared  as  elementary  - 
data  items  in  the  sub-schema. 

b.  A  vector  of  fixed  dimension  can  be  mapped  into  arrays  of  one, 
two,  or  three  dimensions. 

c.  A  vector  of  variable  dimensions  can  be  mapped  into  an  array, 
of  one  dimension. 

d.  A  repeating  group  can  be  mapped  into  a  repeating  group. 

e.  Vectors  and  repeating  groups  may  be  grouped  and  mapped  into 
mew  repeating  groups  in  the  sub-schema. 

f.  Data  items  and  aggregates  which  are  components  of  repeating 
grotip8  in  the  schema  may  only  be  declared  in  the  sub-schema 
aa  components  of  repeating  groups. 

3.  Record  Selection 

Records  are  selected  from  a  database  by  means  record  selection 
expressions.  There  are  three  types  of  record  selection  expressions. 

a.  Record  selection  based  on  identifiers 

Each  record  in  the  data  base  can  be  retrieved  using  its  database 
key.  If  the  location  mode  is  CALC  (location  modes  are  described  in  the 
next  section),  any  record  of  that  type  may  be  retrieved  by  specifying 
record  name  and  the  value  of  the  data  item  specified  as  the  CALC  key. 

b.  Record  selection  based  on  currency 

Throughout  the  execution  of  an  application  program,  the 
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DDBMS  maintains  the  following  currency  status  information  on  the  last 
record  occurrence  accessed  by  the  program: 

a.  each  record  type  (i.e.,  current  of  record  name) 

b.  each  set  type  (owner  or  member)  (i.e.,  current  of  aet-name) 

,  c.  each  realm  (i.e.,  current  of  realm  name) 

d.  Last  record  type  accessed  (i.e.,  current  of  run-unit). 

Record  selection  based  on  currency  allows  records  whose  identifiers  are  v 
currently  saved  by  the  DDBMS  to  be  retrieved  if  any  additional  information  is 
required. 


c.  Positional  record  selection 

Records  may  be  selected  based  upon  their  relative  position  to 
the  current  record  of  set-name.  The  NEXT,  PRIOR,  OWNER,  FIRST,  or  LAST 
ttember  of  a  set  can  be  retrieved  in  this  manner. 

4.  Location  Mode 

Three  access  methods  can  be  employed  to  locate  data. 

a.  Direct  -  retrlevel  using  the  data  base  key. 

b.  CALC  -  key  transformation  (hash  coding)  used  to  map  a  specified 
data  item  into  the  data  base  key. 

c.  VIA  set  name  -  retrlevel  is  based  upon  set  relationships.  In 
order  to  perform  this  operation,  .first  the  proper  set  occurrence 
must  be  selected,  and  then  the  correct  record  occurrence  must 

be  chosen  from  the  members  of  the  set.  In  order  to  select  a 
set  occurrence  the  owner  record  occurrence  must  be  selected. 

The  correct  member  record  occurrence  is  then  selected  by  means 
of  an  argument  provided  to  discriminate  among  the  member  records. 

I .  i>ets 

1.  Concepts 

a.  Each  set  must  have  one  owner  record  type  and  one  or  more 


m 
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member  record  types  In  a  schema. 

b.  Any  record  type  may  be  the  owner  of  one  or  more  sets. 

c.  Any  record  -type  may  be  a  member  of  one  or  more  sets. 

d.  Any  record  type  may  be  both  an  owner  of  one  or  more  sets  and 

a  member  of  one  or  more  sets. 

e.  A  record  type  may  not  be  both  owner  and  member  of  the  same  set. 

f.  A  set  occurrence  is  a  collection  of  one  or  more  logically 
related  record  occurrences. 

g.  Each  occurrence'of  a  set  includes  one  occurrence  of  its  owner 
record . 

h.  A  set  occurrence  which  contains  only  an  occurrence  of  its  owner 
record  is  known  as  an  empty  set . 

2.  Set  Ordering 

A  set  in  the  schema  may  have  an  order  specified.  This 
allows  the  DBMS  to  control  the  logical  order  of  the  record  occur¬ 
rences  within  that  set.  Logical  order  is  independent  of  physical 
placement  of  member  records.  A  listing  of  possible  set  orderings 
is  provided  below. 

a.  Sorted  -  in  ascending  or  descending  sequence  based  upon 
specified  keys. 

b.  First  -  newest  member  is  the  immediate  successor  of  owner 
record. 

c.  Last  -  newest  member  is  the  immediate  predecessor  of 
owner  record. 

d.  Next  -  newest  member  inserted  after  a  selected  set  member. 

e.  Prior  -  newest  member  Inserted  before  a  selected  set 
member. 

f.  Immaterial  -  no  order  specified. 
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3,  Set  Membership 

There  are  four  types  of  membership  that  a  record  may  have  in 
In  a  set. 

a.  Automatic  -  membership  in  the  set  is  established  by  the 
DBMS  when  a  record  occurrence  Is  stored  In  the  database. 

b.  Manual  -  membership  must  be  established  by  a  program  by 
means  of  an  INSERT  command. 

c.  Mandatory  -  once  the  membership  of  a  record  occurrence 
in  a  set  is  established,  the  record  occurrence  cannot  be 
removed  from  the  set.  Only  if  an  owner  record  is  deleted 
are  the  mandatory  members  removed. 

d.  Optional  -  membership  is  not  necessarily  permanent. 

That  is,  it  can  be  removed  from  the  set. 

4.  Set  Mode 

Sets  may  be  organised  in  two  basic  modes  in  the  proposed  DBMS1 
chains  and  pointer  arrays. 

a.  Chains  -  in  a  chained  set  the  records  are  linked  to¬ 
gether  using  pointers.  For  each  record  occurrence  in  the 
set  there  is  a  pointer  to  the  next  (based  on  set  order) 
record  occurrence  in  the  set.  Figure  2  illustrates  a 
chained  set.  Note  that  the  last  member  points  back  to 
the  owner.  Chains  are  always  linked  using  Next  pointers, 
but  they  may  also  be  linked  using  Prior  pointers  as  shown 
in  Figure  3.  In  addition,  each  member  record  may  have  a 
link  to  the  owner  record  as  shown  in  Figure  4.  In  all  of 
the  above  configurations,  the  pointers  to  members  or  the 
set  are  database  keys. 

b.  Pointer  arrays  -  pointer  arrays  are  functionally  equivalent 
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to  chains.  In  a  set  declared  to  have  the  Pointer  Array 
■ode,  the  Next  pointers  are  collected  in  a  list  which 
ia  associated  with  the  owner  record  of  the  set.  Thus 
the  owner  record  is  linked  to  each  member.  Each  member 
record  contains  a  pointer  back  to  the  owner.  Figure  5 
illustrates  the  Pointer  Array  mode.  The  list  of  pointers 
is  maintained  in  the  order  declared  for  the  set. 

It  should  be  noted  that  pointer  arrays  possess  all  of  the  capa¬ 
bilities  of  chains  with  less  overhead.  For  example,  prior  pointers 
are  unnecessary  with  pointer  arrays. 

Schema  DDL 

The  capabilities  of  the  Schema  DDL  for  the  DDBMS  are  outlined 
in  this  chapter.  The  environment  of  the  language  is  presented  along 
with  descriptions  of  each  verb.  The  verb  descriptions  indicate  the 
function  and  the  forrat  of  the  statements. 

1.  Environment 

a.  Organization 

A  schema  DDL  program  consists  of  four  distinct  sections  which 
must  appear  in  the  order  stated  here.  Initially  the  schema  entry 
*  must  appear  to  identify  the  schema.  This  is  followed  by  realm, 

set,  and  record  sections,  in  that  order. 

b.  Lanugage  elements 

The  character  set  and  reserved  words  for  the  schema  DDL  are 


identical  to  those  given  in  Reference  [1J.  The  syntax  of  the  language 
is  essentially  the  same  as  that  of  the  COBOL  Data  Division. 
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2 .  Schema  Section 

The  function  Is  to  Identify  the  schema  of  the  data  base. 

The  general  format  Is': 

SCHEMA  IS  name 
[PRIVACY  clause^ 

where  name  is  an  identifier  up  to  30  characters  and  is  unique 
among  schema  names  in  the  data  base, 
a.  PRIVACY  clause 

Function  is  to  specify  privacy  locks  for  the  operations 
modifvine,  displaying  or  changing  the  privacy  locks. 

The  format  is: 

PRIVACY  LOCK  [FOR  operations]  IS  ■  lock  '*  ”  "  ' 

where  operations  is  any  combination  of  ALTER,  COPYING 
or  LOCKS. 

lock  is  a  literal  or  procedure  name.  There  may  be 
my  number  of  locks.  Separate  locks  may  be  specified  for  each 

operation. 

3.  Realm  Section 

Function  is  to  define  a  realm  and  to  specify  its  storage 
structure. 

Format  is: 

REALM  IS  njmc 
RANCE  IS  r>n-l  THRU  Pn-2 
{PRIVACY  clause] 
where  name  is  an  identifier; 

pn-1  and  pn-2  are  integer  page  numbers,  such  that  pn-1  ^ 
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a.  PRIVACY  clause  -  is  identical  to  that  for  the  schema 
section  except  that  the  operations  are  EXCLUSIVE  RETRIEVAL, 
EXCLUSIVE  UPDATE,  PROTECTED  RETRIEVAL,  PROTECTED  UPDATE. 

4 .  Set  Section 

The  function  of  the  set  section  is  to  specify  the  set  types 
available  to  the  sub-schema  and  application  program.  Options 
include  specification  of  the  method  for  distinguishing  among  sets 
of  the  same  types  and  association  of  privacy  locks  for  the  sets. 

The  set  section  has  two  subdivisions:  a  set  description  and 
member  description.  Tne  member  description  is  optional. 

The  set  description  has  the  following  format. 

SET  clause 

MODE  clause 
ORDER  clause 
PRIVACY  clause 
OWNER  clause 

The  Member  subentry  has  the  following  format: 

MEMBER  clause 

ASC/DES  clause 
SET  SELECTION  clause 

where 

the  PRIVACY,  ASC/DES,  and  SET 
SELECTION  clauses  are  optional, 
a.  SET  clause 

The  SET  clause  names  the  set. 

The  format  is 

SET  IS  name. 


where 
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name  is  an  identifier  up  to  30  characters  in  length. 

b.  MODE  clause  ~ 

Function  is  to  specify  the  organization  of  the 

set. 

There  are  two  formats. 

1:  For  chains, 

MODE  IS  CHAIN  (LINKED  to  Prior] 
ii:  For  pointer  arrays, 

MODE  IS  POINTER- ARRAY 
C.  ORDER  clause 

Function  is  to  specify  order  of  set  by  indicating 

insertion  point  of  newest  member  record. 

There  are  two  possible  formats. 

i:  ORDER  IS  /FIRST 
\LAST 
yNEXT 
/ PRIOR 
(iMMATERI/ 


11:  ORDER  IS  SORTED 


WITHIN  RECORD-NAME 
BY  DATABASE-KEY  I 

DUPLICATES  ARE  (FIRST  A 

/LAST  \ 

(not  allowed^ 

L—  ■ 

d.  PRIVACY  clause 

Function  is  to  specify  privacy  locks  for  the 

set. 

The  format  is  identical  to  that  for  the  schema 
entry,  privacy  clause  except  that  operations  is  FIND, 

OBTAIN,  CONNECT,  or  DISCONNECT. 

e.  OWNER  clause 

Function  is  to  name  the  owner  record  of  the  set. 
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The  format  is 

OWNER  IS  record-name 
f.  MEMBER  clause 


Function  is  t0  name  member  records  of  the  set. 
and  specify  the  type  of  membership  in  the  set. 

The  format  is 


MEMBER  name  (^MANDATORY? ^AUTOMAT Iff)  (LINKED  TO  OWNER] 
(OPTIONAL  j / MANUAL  \ 


(DUPLICATES  ARE  NOT  ALLOWED  FOR  identifiers] 
where 

name  is  a  record; 


identifiers  is  a  list  of  data  Items  in  the  member 
record. 

R.  ASC/DES  clause 

Function  is  to  specify  the  sort  keys  for  a  sorted 

set. 

The  format  is 


(^ASCENDINCaKEY  IS  identifiers  ^DUPLICATES  ARE/FIRST 
}  DESCENDING^  |  >LAST 

I NOT  ALLOWED 


J 


where  _ 

identifiers  is  a  list  of  data  items  in  the  member 


records 

h.  SET  SELECTION  clause 

Function  is  to  define  the  rules  for  selecting 
a  member  of  the  set  for  processing. 

The  format  is 
CL?  SELECTION 


where 


f  CURRENT  OF  SET 
>  LOCATION  MODE  OF  OWNER  \ 
[USINC  {  identifiers  }]  J 
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5. 


Identifiers  is  a  list  of  identifiers  in  the  owner 
record. 

■  .  V. 

Record  Section 

The  function  of  the  record  section  is  to  indicate  the 
record  types  available  to  the  sub-schema  and  application  pro¬ 
gram.  The  data  item  format  is  also  specified. 

The  record  section  is  divided  into  two  portions:  the 
record  description  and  data  description. 

The  format  is  . 

Record  Description 
RECORD  IS  name 


[LOCATION  MODE  clause] 
WITHIN  clause 
[PRIVACY  clause] 

Data  Description 

[levelnumber] 

[PICTURE  clause] 

[TYPE  clause] 

[OCCURS  clause] 

[RANGE  clause] 

[PRIVACY  clause] 


where 


name  is  an  identifier  up  to  30  characters  in  length 
that  is  unique  among  records  in  the  schema; 

levelnumber  is  a  two  digit  positive  Integer, 
a.  LOCATION  MODE  clause 

The  function  of  the  LOCATION  MODE  clause  is  to  define 
a  criteria  for  selecting  a  record  occurrence  or  placing 
a  record  occurrence  in  a  realm. 

There  are  four  formats  for  the  LOCATION  MODE  clause, 
i.  LOCATION  MODE  IS  DIRECT  dbkey 
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vhere 

dbkey  is  a  database  key  Chat  Must  match  the  database  key 
of  the  record  for  a  retrieval  statement, 
ii.  LOCATION  MODE  IS  SYSTEM 

J 

ill.  LOCATION  MODE  IS  CALC  USING  keys. 

DUPLICATES  ARE  I NOT]  ALLOWED 
where  keya  is  a  list  of  one  or  sore  Identifiers 

used  as  arguments  fcr  the  CALC  mapping  function. 

If  DUPLICATES  ARE  NOT  ALLOWED  is  specified,  no  addi- 
clonal  occurrences  of  this  record  type  are  allowed 
to  exist  if  all  of  its  keys  are  identical  to  those 
of  an  occurrence  in  the  same  area, 
iv.  LOCATION  MODE  IS  VIA  setname  SET 
where  setname  is  a  set  of  which  this  record  is  a 
member. 

.  WITHIN  clause 

Function  is  to  define  the  realm  in  which  a 
record  occurrence  is  to  be  placed. 

The  format  Is: 

WITHIN  realm 
where 

realm  is  a  realm  in  the  schema;  '  "•  . 

identifier  is  any  identifier. 

PRIVACY  clause 


Function  is  to  specify  privacy  locks  for  records 
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data  Items,  or  data  aggregates. 

The  format  Is  Identical  to  that  for  schema  entry 
privacy  clauses  except  that: 

for  records,  operations  Is  any  DHL  command; 


for  data,  operations  Is  STORE,  GET,  MODIFY,  or  OBTAIN- 

d.  PICTURE  clause 

Function  is  to  describe  the  characteristics  of  a 
data  item. 

Format  is: 

PICTURE  IS  character  string 
where  character-string  follows 

standard  COBOL  rules  £U  for  picture  specification  of 
strings  and  numbers. 

e.  TYPE  clause 

Function  is  to  describe  characteristics  of  a  data 
Item. 

There  are  three  formats, 
i:  For  a  numeric  data  item 
TYPE  ISf  BINARY)  fFIXED?(REAL  ?  -Inn 

(decimal!  Afloat]  [complex] 

where 

DECIMAL,  FIXED,  REAL  are  the  default  value; 

precision  is  one  (FIXED)  or  two  (FLOAT)  integers 

specifying  the  precision  of  the  number. 

ii:  For  string  data, 

TYPE  IS  (BIT  1 

/CHARACTER)  2121 


s. J 


where  size  Is  the  string  length- 
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ill:  For  a  databasckey 
TYPE  IS  DATABASE-KEY. 
t.  OCCURS  clause 

Function  Is  to  define  a  vector  or  repeating  group 
by  specifying  the  number  of  times  the  data  item  or 
group  occurs  within  a  record. 

The  format  is: 

OCCURS  count  TIMES 
where  • 

count  is  an  Integer  or  identifier, 
g.  RANGE  clause 

The  function  of  the  RANGE  clause  is  to  specify  upper 
and  lower  bounds  for  the  values  a  data  item  may  assume. 

The  format  is 

RANGE  IS  FROM  valuel  TO  value2 

where 

valuel  and  value2  are  literals  of  the  type  correspond¬ 
ing  to  the  data  item  such  that  valuel  ■£.  value2 . 

Subschema  DDL 

The  capabilities  of  the  sub-schema  DDL  for  DDBMS  are  outlined  in 
this  chapter.  The  organization  of  the  language  and  the  format  and 
function  of  each  verb  are  presented.  The  syntax  of  the  sub-schema 
DDL  is  given  in  Appendix  B. 

1.  Organization 

A  subschema  DDL  program  is  divided  into  four  sections 
which  must  occur  in  the  sequence  specified.  The  subschema 
identification  section  appears  first  followed  by  the 


realm,  set,  and  record  sections. 
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2.  Sub-Schema  Section 

The  sub-schema  section  defines  the  sub-schema.  The 
general  format  Is 

SOB-SCHEMA  IS  namcl  WITHIN  name2 
PRIVACY  LOCK  clause 
PRIVACY  KEY  clause 

where  namel  is  an  Identifier  up  to  30  characters  and  Is  unique 
among  subschema  names  In  the  schema; 

•  riame-2  Is  a  schema  name.  _  _  _  _ 

a.  PRIVACY  LOCK  clause 

Function  is  to  specify  privacy  locks  for  the  sub¬ 


schema  . 

The  format  is  identical  to  the  PRIVACY  clause 
for  schema  entry  expect  that  operations  is  LOCKS,  INVOKING, 


or  ALTERING, 
b.  PRIVACY  KEY  clause 

Function  is  to  specify  a  key  for  accessing  a  schema. 


The  format  is 
PRIVACY  KEY  IS 


[literal  } 

Tprocedur enamel 


3-  Alias  Section 

The  alias  section  provides  for  the  renaming  of  elements 
In  the  sub-schema. 

The  format  is 

T"*  \ 

ALIAS  OF  name  1  REALM-NAME  I  IS  namo2 
(SET-NAME 
^RECORD-NAME 

where  namel  is  the  a  realm,  set,  or  record  in  the  schema; 

name 2  is  a  identifier  by  which  the  object  name!  shall  be 
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*\ 


4. 


Identified  in  the  sub-schema; 

the  phrases  REALM-NAME  SET-NAME,  or  RECORD-NAME  are  necessary 
if  naael  Is  not  unique  to  the  schema. 

Realm  Section 

The  function  of  the  realm  section  Is  to  enumerate  the 
realms  of  the  schema  to  be  Included  In  the  sub-schema. 

The  format  Is  » 


where 

name  is  a  realm  In  the  schema; 


ALL  means  all  realms  in  the  schema  are  Included  In 
the  sub-schema. 

5.  Set  Section 

The  purpose  of  che  set  section  is  to  enumerate  the  sets 
defined  In  the  schema  that  are  to  be  Included  in  the  sub¬ 
schema. 

The  format  Is 


SD 


/ 


(SET  SELECTION  clause] 


where 

aetl  is  a  set  in  the  schema; 

ALL  means  all  sets  in  the  schema  are  Included  in  the  sub¬ 
schema. 

a.  SET  SELECTION  clause  \ 

The  function  is  to  define  the  rules  governing  the 
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selection  of  a  set  occurrence  within  a  sub-schema  in 
order  to  operate  upon  a  member  record. 

The  format  is 

SET  SELECTION  FOR  record  IS  VIA  setl  OWNER 
VIA  setl  OWNER 


SYSTEM 
CURRENT 
ldent if lerl 

VALUE  OF  ident i f iers2  IS  identifiers! 


[via  set2  OWNER  VALUE  OF  identifiers*  IS  identifier sSj 


record  is  a  member  record  of  setl; 

setl  is  the  set  being  defined  by  the  set  description 
section; 


ldentlflers2  is  a  list  of  data  items  in  the  owner 
record  of  setl ; 

identifiers!  is  ->  list  of  data  items  whose  contents 
•re  values  contained  in  the  data  items  of  the  corresponding 
elements  of  identlf iers2; 

•ct2  must  have  an  owner  record  that  is  a  member  record 
of.  setl ; 

Identifiers*  is  a  list  of  data  items  in  the  owner 
record  of  set2 ; 

ldent if iers5  is  a  list  of  data  Items  whose  contents 
are  values  contained  in  the  data  items  of  the  corresponding 
elements  of  Identifiers*. 


6 .  Record  Section 

The  purpose  of  the  record  section  is  to  define  the  records 
of  the  schema  that  are  to  be  Included  in  the  subschema. 
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The  format  of  the  record  section  la  divided  into  two  entries. 
Record  Description 
[Data  Description] 

The  format  for  the  Record  Description  is 
01  record  name 
[WITHIN  clause] 

The  Data  Description  has  the  following  format 
level  number  datahasenaae 

PICTURE  clause 
USAGE  clause 
OCCURS  clause 
RANGE  clause 

where  all  clauses  are  optional, 
a.  WITHIN  clause 

function  is  to  define  and  restrict  selection  of  occurrences 
of  the  record  named. 

The  format  is 
BUKIN  realm 

where  realm  is  a  realm  name  in  the  schema, 
b.  PICTURE  clause 

The  format  is  identical  to  PICTURE  clause  of  schema  DDL 
record  entry. 


\ 


c.  USACE  clause 

Function  Is  to  specify  format  of  COSOL  data  Item. 

the  format  Is 

USACE  IS  f BIT 

!  COMP-n 
DISPLAY 
'  DISPLAY-n 
DATABASE- K 
INDEX 
^  INDEX-n 

d.  OCCURS  clause 

The  format  is  identical  to  the  OCCURS  clause  of  schema 
DDL  record  entry. 

e.  RANGE  clause 

The  format  is  Identical  to  RANCE  clause  of  schema  DDL 
record  description. 

V.  DHL 

The  Data  Manipulation  Language  for  DDBMS  is  specified  in  this  chapter. 
The  DHL  verbs  which  are  used  to  extend  the  COBOL  host  language  are 
presented.  Appendix  C  gives  the  DML  syntax. 

A  DML  program  is  in  fact  an  augmented  COBOL  program.  Thus  the 
overall  structure  is  that  of  a  COBOL .program — Identification  division, 

Data  division,  and  Procedure  division.  Each  division  of  the  DML  program 
includes  standard  COBOL  features.  These  features  are  not  discussed 


here.  ONly  the  DML  extensions  are  presented 
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1.  Data  Division 

The  lone  DML  extension  to  the  COBOL  Data  Division  la  the  Schema 
Section.  The  Schema  Section  consists  of  an  INVOKE  clause  which  is 
used  to  call  In  the  appropriate  sub-schema  for  the  application  program, 
a.  INVOKE  clause 

Function  is  to  identify  sub-schema  to  be  accessed  by  DML  program. 
The  format  is 

INVOKE  sub-schema  OF  SCHEMA  schema 

where  sub-schema  is  a  valid  sub-schema  name,  and  schema  is  the 
•  ” 

name  of  the  schema  containing  sub-schema. 

2.  Procedure  Division 

The  following  verbs  have  been  added  to  COBOL  in  the  DML  to  provide 
for  a  full  range  database  operations: 

ACCEPT 

CONNECT 

DISCONNECT 

ERASE 

FIND 

FINISH 

GET 

IP 

MODIFY 

OBTAIN 

BEADY 

STORE 

USE 

a.  ACCEPT 


The  ACCEPT  statement 


causes  the  contents  of  the  specified  currency 
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indicators  to  be  accessed  and  provides  a  means  of  deriving  the  realm 

name  of  a  data  base  key. 

There  are  two  formats: 


i.  ACCEPT  identifier  1 


11.  ACCEPT  identifier  2 


FROM 


record 

realm 

aet 


CURRENCY 


FROM 


record 

set 

identifiers 


REALM  -  NAME 


where 

identifier!  and  Identifier 2  are  data  base  keys; 
record  is  a  record  name; 
realm  is  a  realm  name; 
set  is  a  set  name; 

identifier 2  is  an  alphanumeric  data  item. 


b.  CONNECT 

The  CONNECT  statement  causes  a  record  stored  in  the  data  base 
to  become  a  member  of  one  or  more  secs  in  which  the  record  has  been 
defined  as  a  possible  member. 

The  format  is: 

CONNECT  record  TO  C sets') 

W )  . 

where 

record  is  the  record  name; 

sets  is  a  list  of  sets  of  which  record  may  be  a  member; 

ALL  means  record  will  become  a  member  of  all  possible  sets, 
c.  DISCONNECT 

The  DISCONNECT  statements  removes  a  record  from  one  or  more  sets. 


The  format  is 

DISCONNECT  record  FROM  C  sets  7 

l  ALL  ] 


1 
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vhere 

record  is  the  record  name; 

aets  is  a  list  of  sets  of  which  record  is  a  member; 

ALL  means  record  is  removed  from  all  sets  of  which  it  is  a  member. 

d.  ERASE 

The  ERASE  statement  removes  a  record  from  the  data  base. 

The  format  is 

MEMBERS 

where 

record  is  the  record  namej 

PERMANENT  means  that  all  permanent  members  of  the  set  owned  by 
the  current  record  of  the  run-unit  will  be  erased.  Transient  members 
of  the  affected  sets  are  Created  as  though  they  were  DISCONNECTed,' 

SELECTIVE  means  that  actions  identical  to  that  of  the  SELECTIVE 
option  are  taken  except  that  when  a  transient  member 
Chat  is  not  a  member  of  any  other  set  is  encountered,  it  is  removed 
from  the  data  base,' 

ALL  means  that  all  members  of  sets  owned  by  the  current  record 
of  run-unit  are  removed  from  the  data  base  along  with  all  members  of 

any  sets  owned  by  records  being  removed  from  the  data  base  by  the 
ERASE  command . 

e.  FIND 

The  function  is  to  establish  a  record  occurrence  as  current 
of  run-unit,  realm,  record-name,  and  set.  Tbe  option  exists  for 
retaining  all  currency  indicators  except  current  of  run-unit. 

The  format  of  the  FIND  statement  is 


ERASE  record 


PERMANENT 

SELECTIVE 

ALL 
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FINDTse  |  RETAINING  CURRENCY  FOR  f MULTIPLE^ 

)  RECORD  ( 

{  REALM  > 

I  SET 
(sets 

where  rse  is  a  record  selection  expression; 

sets  is  a  list  of  sets  in  the  sub-schema j 
MULTIPLE  means  no  currency  indicator  except  run-unit  will  be 
updated . 

The  record  selection  expression  may  have  one  of  the  following 
formats-.  • 


i.  DBKEY  IS  identifier! 


ii.fANY 


^duplicate] 


recordnamel 


ill.  DUPLICATE  WITHIN  setl  USINC^ldentif lers^ 


iv 


^ NEXT 
PRIOR 
FIRST 
LAST 

/  lntegerl 
(identifier3 


[recordname2]  WITHIN 


v.  CURRENT 


[recordname2] 


"within 


Vi.  OWNER  WITHIN  set2 


vii.  recordname2  WITHIN  setl  [CURRENT] 
[USING  (identlfiers2j ] 
where 


identifier!  must  be  a  data  base  key; 
recordnamel  must  have  a  location  mode  of  CALC; 
setl  is  a  set  in  the  sub-schema; 

ldentlflers2  is  a  list  of  identifiers  defined  in  the  current 
record  of  setl ; 

lnteRerl  is  an  integer; 
identifier!  is  an  integer  data  item; 
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recordnnmi-2  is  the  current  record  of  set2  and  realml: 
realml  is  a  realm  in  the  sub-schema; 
set2  must  not  be  a  singular  set; 

ANY  means  that  in  case  of  several  records  with  CALC  keys 
equal  to  that  of  recordnamel.  the  record  with  the  lowest  data 
base  key  and  Identical  CALC  key  is  selected; 

DUPLICATE  means  that  in  case  of  several  records  with  CALC  keys 
equal  to  that  of  recordnamel,  the  record  with  the  data  base  key 
with  the  identical  CALC  key  occurring  next  after  the  current  of 
run  unit  is  selected. 

f.  FINISH 

The  FINISH  statement  terminates  the  availability  of  one  or  more 
realms  to  the  program. 

The  format  is 
FINISH  realms, 
where 

realms  is  a  list  of  realms  in  the  sub-schema. 

g.  GET 

The  function  is  to  transfer  the  contents  of  a  record  occurrence 
into  the  User  Working  Area. 

The  format  is 
GET  [Identifiers] ; 
where 

identifiers  is  a  list  of  data  base  identifiers  which  are  contained 
in  Che  current  record  of  run-unit. 

h.  MODIFY 

The  MODIFY  statement  is  used  to  alter  the  contents  of  one  or  more 
data  items  in  the  current  of  run-unit  record  or  to  change  the  set 
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membership  of 

the  record. 

There  are 

two  formats. 

i.  MODIFY 

-t 

(including? 

(all  7  MEMBERSHIP 

[(ONLY  J 

[sets]  J 

ii.  MODIFY  identifiers 

^INCLUDING 

Tall-?  membership"! 

j 

where 

sets  is  a 

list  of  sets  of  which 

is  a  member; 

• 

identifiers  is  a  list  of  data  items  contained  in  the  current  of 
run-unit  record; 

ONLY  means  that  the  contents  of  data  items  are  not  changed. 


i.  OBTAIN 

The  OBTAIN  statement  performs  the  function  of  a  FIND  statement 
Immediately  followed  b;’  ■»  GET  statement. 

The  formats  for  OBTAIN  are  identical  to  those  of  FIND. 


J.  READY 


The  READY  statement  prepares  a  realm  for  processing. 
The  format  is 
READY  realm 


lUSAGE  mode  is  [exclusive 

/"retrieval] 

PROTECTED 

(^UPDATE  j 

u  L 

•m 

where 


realm  is  the  name  of  a  realm  in  the  sub-schema, 
k.  STORE 

The  STORE  statement  causes  a  record  to  be  stored  in  the  data 


base. 
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The  format  Is 
STORE  record 

RETAINING  CURRENCY  FOR  ( MULTIPLE] 

REALM  ( 

SET  ( 

sets  1 

^RECORD  J 

where 

record  is  a  record  In. the  sub-scheaa;  * 

seta  Is  a  list  of  sets  of  which  record  is  e  member; 

MULTIPLE  means  that  all  currency  indicators  except  run-unit  will 
be  retained. 

USE 

The  USE  statement  specifies  procedures  that  produce  privacy 

keys. 


The  format  is 

USE  FOR  PRIVACY 

Oon  (exclusive]  ( 

_  [protected!  ( 

P5N  /CONNECT  X  ' 
/  DISCONNECT 
\  STORE 
\ERASE 

(ERASE  PERMANENT. 

] ERASE  SELECTIVE) 
/ERASE  ALL 


<,  retrieve 

FOR 


( UPDATE 

r' 


a 


FOR 

records 

RECORDS 


realms 

[realms 


V 


GET 

MODIFY 

FIND 

OBTAIN 


FOR 


FOR 


‘.ON  (  CONNECT 
\  FIND 
I OBTAIN 
/  DISCONNECT  j 

{Ton  /'get  V 

\  MODIFY/ 

J  OBTAIN \ 

(  STORE/ 

where 

realms  is  a  list  of  realms  in  the  sub-mcfcema; 


records  is  a  list  of  records  in  the  sub -schema; 


sets  Is  a  list  of  secs  in  the  sub-schema; 
identifiers  is  a  list  of  Identifiers  in  the  aub-scheaa. 
REALMS,  SETS,  or  RECORDS  Implies  a  privacy  key 
will  be  generated  for  all  realms,  sets,  or  records  In  the 

« 

sub-schema . 

'  :  DMCL 

A.  Overview 

The  CODASYL  committee  has,  not  specified  a  standard  Device  Media  Control 
Language.  The  function  of  the  DMCL  is  to  map  the  logical  data  base  to  a 
physical  storage  facility.  This  type  of  mapping  is  typically  carried  out  by 
,:b  control  language  statements  in  an  application  program.  In  the  DDBMS,  the 
purpose  of  the  DMCL  is  to  spare  the  applications  programer  and  data  base 
administrator  the  trauma  of  understanding  the  job  control  languages  of  all 
machines  that  may  be  involved  in  accessing  data.  Each  application  program 
nas  a  set  of  DMCL  instructions  associated  with  it  by  the  DBA.  The  DBA 
produces  high  level  DMCL  statements  which  are  mapped  into  Job  control 
statements  for  the  appropriate  machines  by  the  DMCL  translator. 

The  DMCL  for  this  system  is  intended  to  be  easy  to  use  and  under- 
tand.  It  differs  from  existing  DMCL’s  (6J  in  that  the  machine  con- 
ing  acceas  to  the  data  must  also  be  specified.  The  remainder  of 

his  section  defines  the  function  and  format  of  the  DDBMS  DMCL.  Appendix  D 
ontains  the  DMCL  syntax. 

8*  Specifications 

A  DMCL  program  is  composed  of  four  sections  as  shown  below. 

DMCL  Description 
BUFFER  Description 
REALM  Description 
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PROCESSOR  Description 

1.  DHCL  Description 

The  purpose  of  the  DMCL  description  is  to  naae  the  DHCL  segment  end 
Identify  the  schema  which  is  being  mapped  to  physical  storage. 

*  The  format  is 

DD  daclname  FOR  schemaname 
where 

daclname  is  the  name  of  DMCL  segment; 
schemaname  is  the  sohema  being  described. 

2.  Buffer  Description 

The  buffer  description  is  intended  to  assign  a  naae  and  sice  to  the 
system  buffer  area  and  denote  the  buffer  page  size. 

The  format  is 
XD  name 

PACE  SIZE  IS  lntegerl  BYTES 
BUFFER  SIZE  IS  integer?  PAGES 

where 

naae  Is  the  buffer  name; 
lntegerl  and  integer?  are  integers. 

3.  Realm  Description 

The  realm  description  lists  the  realas  in  the  schema  that  are  mapped  in 
this  DMCL  segment. 

*D?realms~? 

[all  J 

where 

realas  is  a  list  of  realms  in  the  schema; 

ALL  means  all  realms  of  the  schema  are  to  be  included  in  the  DMCL  segment. 


A.  Processor  Description 

The  processor  description  section  lists  the  machines  which  have  access 
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to  the  schema. 

The  format  is 

BACKEND  processorld 

HOSTS jprocessorids] 

(ALL  J 

where 

processorld  is  the  network  Identifier  of  the  processor  controlling 
sccess  to  the  schema; 

procesaorlds  is  a  list  of  the  network  identifiers  of  processors 

upon  which  application  programs  that  reference  the  schema  can  reside; 

ALL  means  that  any  processor  in  the  network  (including  future 
configurations)  may  reference  the  schema. 

VII.  Utilities 

A.  Overview 

All  CODASYL  based  data  base  systems  consist  of  the  same  basic  functional 
components,  schema  DDL,  sub-schema  DDL,  DKL,  DMCL.  (Although  in  some  cases  ^ 

the  functions  of  two  languages  are  combined  into  a  single  language  [7]).  One 
important  area  in  which  this  uniformity  evaporates  is  data  base  utilities. 

The  CODASYL  committee  suggested  a  rather  brief  list  of  utility  functions  but 
did  not  formally  incorporate  any  into  their  specifications. 

The  utilities  of  a  DBMS  have  a  major  impact  on  the  useability  and  overall 
performance  of  the  system.  A  powerful  set  of  utility  programs  permits  the 
DBA  to  carry  out  his/her  duties  in  a  precise  and  efficient  manner.  Since  the 
DDBMS  is  physically  a  more  complex  system  than  any  other  CODASYL-derived  DBMS, 
an  extensive  set  of  utilities  programs  is  Included  in  the  system.  Many  of 
t'ne  utilities  are  for  the  use  of  the  DBA.  However  several  are  intended  to 
facilitate  the  production  of  application  programs.  Certain  utilities 
are  available  at  execution  time  (such  as  those  Involved  in  recovery)  while 
others  are  off  line  functions  (i.e.  changing  page  sizes).  The  utilities  will 
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be  Hated  below,  grouped  by  type  of  usage. 

B.  Off-Line  Functions 

1.  Dump  to  tape  -  This  routine  la  used  to  transfer  a  sub-schema 
realm,  set,  or  record  to  a  tape  file.  Each  dump  label  indicates  the  name 
and  type  of  data  being  transferred.  The  date  of  the  transfer  is  included 
in  the  header  for  archival  purposes. 

2.  Print  -  This  routine  allows  the  printing  of  any  portion  of  the 
data  base  down  to  the  record  level.  The  format  of  the  records  is  as 
specified  in  the  schema.  Sets  are  printed  in  their  defined  order. 

3.  Edit  -  The  editing  utility  is  employed  to  modify  the  values 

of  data  items  in  the  data  base.  The  structure  of  the  data  base  is  not 
changed.  That  is,  sets  or  records  may  not  be  added  or  deleted.  However, 
set  relationships  may  be  altered  as  a  result  of  changes  to  data  items. 

4.  Initialization  -  This  routine  is  used  to  establish  a  data  base 
on  secondary  storage.  The  format  of  the  data  base  is  defined  by  the 
object  sub-Bchema  produced  by  a  sub-schema  DDL  compile.  The  data  is 
loaded  from  either  cards  or  tape  using  a  specified  format. 

5.  Data  Base  Reorganization  -  This  routine  modifies  the  physical 
structure  of  the  data  base.  Among  the  operations  performed  by  this 
utility  are  changing  page  size,  altering  the  placement  of  overflow  or 
index  pages,  moving  realms  or  sub-schemata  to  different  physical  devices, 
and  transferring  control  of  portions  of  the  data  base  (not  lower  than  the 
realm  level)  to  another  processor  in  the  network.  The  primary  motive  for 
using  the  reorganization  routine  is  to  attempt  to  fime  tune  the  performance 
of  the  DDBMS  by  better  distributing  the  data  to  avoid  secondary  storage 
access  bottlenecks.  The  information  upon  which  the  reorganization  is 
based  is  derived  from  the  statistical  analysis  routine  (see  VII  B.7). 

6.  Carbage  collection  -  When  a  substantial  number  of  additions  and 
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de let ions  have  been  performed  on  the  data  base,  secondary  storage  may 
become  highly  segmented  with  many  small  pockets  of  unused  space.  In  order 
to  lsiprove  the  efficiency  of  secondary  storage  utilisation,  a  garbage 
collection  routine  can  be  employed  to  compact  the  used  and  free  space 
on  each  page.  The  result  of  the  garbage  collection  la  to  create  more 
locations  for  records  on  the  data  pages.  Each  garbage  collection  is 
targeted  for  a  particular  secondary  storage  device.  Information  concerning 
the  need  for  garbage  collection  is  obtained  from  the  statistical  analysis 
utility  described  in  the  next  paragraph. 

7.  Statistical  analysis  -  The  DBA's  guide  to  the  performance  of  the 
DDBMS  is  the  statistical  analysis  utility.  This  routine  tabulates  and 
sunnarlzes  the  statistical  information  gathered  by  the  on-line  data  base 
activity  logging  routine  (Section  VII  C.l).  Among  the  performance  descrip¬ 
tors  processed  by  this  utility  are  the  total  and  average  number  of  DML 
operations,  reads,  writes,  and  currency  of  set  references  per  schema,  sub¬ 
schema,  realm,  set  and  recoiu;  page  content  and  distribution  statistics  ; 
average  and  total  numbers  of  page  accesses  and  overflows;  number  of 

collisions  per  CALC  value;  and  queuing  information  for  DBMS  host  and 
back-end  tasks,  communication  facilities,  and  secondary  storage  devices. 

8.  Integrity  check  -  In  a  DBMS,  perhaps  the  most  difficult  errors 
to  detect  are  those  which  produce  scattered  erroneous  results  but  which 
do  not  cause  catastrophic  failures.  Because  of  the  large  amount  of 
software  and  hardware  resources  necessary  to  realize  the  DDBMS,  there  is 
a  definite  likelihood  that  minor  errors  may  periodically  occur.  The 
integrity  check  utility  is  executed  in  order  to  verify  the  absence  of 

a  certain  class  of  errors  in  the  data  base  or  to  locate  portions  of  the 
data  base  that  contain  improper  information.  Two  types  of  information, 
data  and  links,  are  verified  in  the  integrity  check.  Data  items  that 
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have  the  RANGE  attribute  are  tested  to  Insure  compliance  with  the  estab¬ 
lished  limits.  Set  linkages  are  verified  along  with  CALC  chain  linkages 
which  have  been  built  up  due  to  collisions  on  CALC  keys. 

9.  Restore  from  Tape  -  This  routine  allows  the  reconstruction  of 
all  or  part  of  a  data  base  from  a  tape  created  by  the  Dump  to  Tape 
utility  (VII  B.l). 

10.  Security  Violation  -  The  security  violation  utility  is  an  pn-line 
routine  under  the  control  of  the  DBA.  It  is  called  by  the  security  monitor 

(VII  C.  2)  whenever  a  security  violation  is  detected.  The  security  violation 
utility  determines  the  action  to  be  taken  in  response  to  the  unauthorized 
attempt  at  data  base  usage.  Among  the  possible  responses  are  recording 
user  id  and  illegal  action,  displaying  a  message  to  the  user,  terminating 
and  rolling  back  the  offending  process,  or  notifying  the  operator  of 
the  point  of  origin  of  the  illicit  task  so  that  the  user  may  be  contacted 
by  security  personnel. 

11.  Manipulate  Locks  -  A  special  version  of  the  editing  utility  is 
wed  to  alter  privacy  locks.  This  routine  can  only  be  used  by  the  DBA  , 

C.  On-Line  System  Functions 
< 

1.  O*--  Base  Activities  Logging  -  The  log  routine  i;:  a  multifaceted 
*®®order  data  base  activity.  Information  such  as  DHL  commands,  page 
Images,  and  statistical  data  is  accumulated  for  rollback,  recovery,  and 
analysis  purposes.  The  information  is  recorded  onto  either  a  tape 

or  disk  file  whenever  a  DML  operation  is  processed  by  either  a  hose  or 
back-end  machine.  The  reason  for  incorporating  both  statistical  and 
operational  information  into  a  single  file  is  that  the  requirement  for 
separate  physical  devices  may  be  prohibitive  in  a  minicomputer  configura¬ 
tion. 

2.  Security  Monitor  -  The  security  monitor  is  activated  when  a  user- 
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supplied  privacy  key  fall9  to  match  the  DBA-specified  lock.  As  indicated 
in  the  description  of  the  schema  DDL,  privacy  locks  can  be  established 
at  all  levels  in  the  DDBMS.  Upon  detection  of  an  illicit  access  attempt, 
the  security  monitor  routine  calls  the  security  violation  utility  (VII  B.10) 
which  handles  the  intrusion  in  an  appropriate  manner. 

3.  Realm  Enable/Disable  -  The  DBA  may  selectively  disable  all  access 
to  a  realm  and  later  re-enable  access  by  means  of  these  routines. 

4.  Rollback  -  The  rollback  utility  is  employed  to  reverse  the  effect 
of  a  single  DML  command,*  a  sequence  of  cosaands,  or  a  complete  task. 

During  rollback,  the  affected  realms  are  first  disabled  by  the  realm 
disable  utility  (VII  C. 3).  The  effects  of  all  DML  commands  specified  for 
rollback  are  then  reversed.  Realms  are  enabled  when  they  are  not  affected 
by  any  command  waiting  to  be  retracted. 

5.  Checkpoint  -  The  optional  checkpoint  utility  involves  the  periodic 
dumping  of  a  sub-schema  to  back-up  storage.  The  checkpoint  utility  is 
activated  whenever  a  sub-schema  is  Invoked  by  an  application  task  and 
upon  termination  of  chat  task.  During  a  checkpoint  dump,  all  realms  of 
the  sub-schema  must  be  disabled.  The  checkpoint  dump  also  contains  status 
information  and  the  UWA  for  all  active  user  Casks. 

6.  Recovery  -  The  recovery  rout'ine  is  initiated  when  the  DDBMS  is 
determined  to  have  operated  erroneously.  If  the  checkpoint  option 
(VII  C.5)  has  been  employed,  the  affected  realms  are  restored  from  their 
most  recent  checkpoints.  All  active  tasks  accessing  those  realms  are 
restored  to  the  status  they  held  at  the  time  of  the  checkpoints. 

7.  Restart  -  In  the  case  of  catastrophic  failure,  the  data  base 
must  be  completely  restored  from  a  Dump  Tape  (VII  B.9)  and  all  user  tasks 
must  be  restarted.  New  checkpoint  and  audit  files  must  be  created. 

8.  Encryption  -  For  purposes  of  security,  the  stored  data  may  be 
encoded  so  that  illicit  access  without  the  proper  decoding  operations 


would  be  without  benefit  to  the  interloper.  Use  of  the  decoding  opera¬ 
tion  must  be  carefully  restricted  by  privacy  locks. 

9.  Data  compression  -  Since  storage  is  a  critical  resource  in  the 
DDBMS,  a  data  compression  utility  has  been  included  to  reduce  the 
*  secondary  storage  requirements  of  data  bases.  The  data  compression  and 
expansion  Introduce  some  time  overhead  while  producing  a  decrease  in 
secondary  storage  requirements. 

10.  Trace  -  The  trace  utility  serves  as  a  debugging  aid  to  application 
programmers.  It  can  be. activated  and  deactivated  under  program  control. 
The  trace  output  Indicates  the  statements  executed,  data  transferred, 
status  conditions,  set  contents,  values  of  CALC  keys,  currency  indicators, 
etc. 

VIII.  Special  Features 
A.  Introduction 

Many  features  may  be  added  to  a  basic  CODASYL  DBMS  to  enhance  its 
useabillty.  In  this  chapter,  six  such  additions,  Query  Language,  Report 
Writer,  Data  Dictionary,  Data  Base  Administrator  Language,  Debugging  Facility, 
and  an  Interactive  Data  Base  Design  Language  are  discussed  .  The  initial 
version  of  DDBMS  will  not  include  any  of  these  enhancements.  They  will  be 
Incorporated  into  the  DDBMS  as  soon  as  possible. 


B.  Query  Language 

A  query  language  provides  the  unsophisticated  user  with  the  ability  to 
access  the  data  base  Interactively  in  an  easy  to  use  format.  The  query 
language  permits  Information  in  any  sub-schema  to  be  operated  upon  by  commands 
input  at  a  terminal.  Naturally  all  privacy  requirements  must  be  met  before 
such  access  can  transpire.  The  organization  of  the  software  comprising  the 
query  language  facility  is  shown  in  Figure  6.  In  essence,  each  query  language 
conand  is  translated  into  one  or  more  DML  commands  which  access  the  data  base 


DATA/STATUS 


Figure  6 

Query  Language  Software  Structure 
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and  a  aeries  of  Network  Control  Language  (NCL)  [8]  statements  which  initiate 
the  data  base  access  and  control  the  transfer  of  information.  Building  the 
query  language  on  the  NCL  and  the  DHL  facilitates  the  implementation 
and  produces  a  generalized  and  portable  facility. 

C.  Report  Writer 

In  a  data  base  system  capable  of  maintaining  a  large  variety  of  data, 
there  is  a  requirement  for  many  diverse  reports.  Rather  than  force  thd 
applications  program  to  completely  specify  the  format  of  each  document  to  be 
generated,  a  report  writer  feature  is  to  be  incorporated  in  DDBMS.  The 
report  writer  is  sufficiently  general  to  allow  any  Information  on  the  data 
base  to  be  retrieved  and  printed  in  any  format  desired. 

D.  Data  Dictionary 

The  data  dictionary  facility  provides  a  complete  description  of  the  data 
base.  It  is  used  in  the  initialization  and  loading  of  the  data  base.  The 
data  dictionary  contains  Che  schemata,  sub-schemata,  and  their  associated 
DMCL  segments  which  are  extracted  prior  to  each  application  program  execution. 

A  listing  of  the  data  dictionary  will  indicate  the  current  structure  of  the 
data  base. 

E.  Data  Base  Administrator  Language 

The  DBA  language  is  an  extension  of  .the  query  facility.  The  DBA  language 
■takes  it  possible  for  the  DBA  functional  utilities  (Sec.  VII  B.)  to  be  initiated 
directly  from  a  terminal  by  means  of  high-level  commands.  It  is  imperative 
that  access  to  the  DBA  language  be  carefully  limited  since  misuse  of  its 
powerful  features  could  play  havoc  with  the  integrity  of  the  data  base. 

F.  Interactive  Data  Base  Design  Language 

The  initial  description  of  the  data  base  in  terms  of  a  schema  involves 
considerable  effort  on  the  part  of  the  DBA.  A  commonly  used  tool  is  the  Bachman 
diagram  (see  Figure  7  for  an  example).  Once  a  Bachman  diagram  has  been  developed 


Figure  7 

Sample  Bachman  Diagram 
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it  Is  a  relatively  straightforward  process  to  map  to  schema  DDL  statements. 

The  Interactive  Data  Base  Design  Language  (IDBDL)  will  allow  the  DBA  to 
graphically  input  a  Bachman  diagram  and  have  schema  DDL  code  produced  as  out¬ 
put.  Facilities  for  creating,  deleting, and  modifying  diagrams  are  also  Included 
la  IDBDL. 

0.  Debugging  Facility 

The  debugging  facility  provides  the  capability  to  teat  a  program  without 
affecting  a  real  data  base.  The  debugger  operates  in  an  interactive  environ¬ 
ment  to  provide  a  maximum  capacity  for  program  testing.  Among  the  features 
of  the  debugger  are  tracing,  insertion  and  deletion  of  sets,  records,  and  data 
Items,  breakpoints,  and  statistical  output. 

IX.  DDBMS  and  Relational  Data  Bases 

Currently,  the  two  principal  types  of  organization  for  commercially  avail¬ 
able  data  bases  are  network  (CODASYL)  or  hierarchical  (such  as  IBM's  IMS).  There 
are  many  systems  which  are  hybrids  of  these  two  primary  types.  Hybrid  systems 
Include  TOTAL,  ADABAS,  System  2000,  INQUIRE.  In  virtually  all  commercially 
vended  data  base  management  systems,  the  user  is  aware  of  the  physical  struc¬ 
ture  of  the  data  base. 

The  concept  of  a  relational  data  base  was  initially  proposed  by  E.  F. 

Codd  [9],  also  see  References  (10-12].  The  method  of  physical  organization 
of  the  data  base  is  transparent  to  the  user  of  a  relational  system.  A  rela¬ 
tional  DBMS  is  very  well  suited  for  the  formulation  of  complex  queries  and 
the  specification  of  intrinsic  relationships  among  the  data  items.  Many 
experts  feel  that  the  relational  approach  holds  the  key  to  future  data  base 
development  [13].  The  main  drawback  thus  far  has  been  the  excessive  amount 
of  space  required  to  maintain  the  tables  specifying  the  relations. 

If  the  potential  of  the  relational  method  is  realized,  DDBMS  and  other 
CODASYL  systems  must  have  a  means  of  bridging  the  gap  between  the  relational 
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snd  network  organizations.  Some  investigation  has  been  conducted  to  determine 
which  features  of  the  CODASYL  systems  would  be  most  compatible  with  the 
relational  model  [14] .  The  following  features  in  Che  DDBMS  can  be  used 
for  the  purpose  of  forming  a  bridge  with  the  relational  model. 

1.  OWNER  IS  SYSTEM. 

2.  ORDER  IS  IMMATERIAL. 

3.  LOCATION  MODE  IS  SYSTEM. 

4.  SET  MEMBERSHIP  IS  MANDATORY  AUTOMATIC. 

By  making  use  of  the  features  listed  above  and  with  an  Improved  query 
language,  DDBMS  should  be  capable  of  functioning  in  a  manner  similar  to  a 
'elational  data  base  system. 

.<  Comparison  With  Other  CODASYL  DBMS 

A.  Overview 

DDBMS  is  a  larger  subset  of  the  CODASYL  specifications  than  any  commer¬ 
cially  available  DBMS.  A  detailed  comparison  of  DDBMS  with  four  CODASYL 
derivatives,  DBMS-10,  DMS-1100,  EDMS,  and  IDMS  is  given  in  the  Tables  of 
Appendix  E.  The  main  differences  between  DDBMS  and  the  other  systems  are 
expounded  upon  in  the  succeeding  paragraphs. 

B.  Unique  Features  in  DDBMS  (among  CODASYL  DBMS  systems) 

1.  LOCATION  MODE  IS  SYSTEM  -  this  feature  is  included  for  future 
cmpatlbllity  with  relational  DBMSs. 

2.  Access  locks  for  query  store  and  modify  -  provided  as  part  of 
extensive  security  system. 

3.  ORDER  IS  IMMATERIAL  -  a  feature  included  for  relational  DBMS  compati¬ 
bility. 

4.  Security  facilities  at  all  levels  of  the  data  base. 

C.  Features  Not  Contained  in  CODASYL  But  Found  in  Other  Network  DBMSs 

1.  NEXT  as  default  set  linkage  -  saves  coding  in  DDLs. 

2.  Storage  specifications  contained  in  schema  DDL  -  allows  a  more 
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comprehensive  definition  of  data  base  in  the  schema  DDL. 

3.  INVOKE  SUB-SCHEMA  DHL  Verb  -  explicit  request  of  sub-schema  for 
application  program. 

4.  OBTAIN  DHL  Verb  -  combination  of  FIND  and  GET  to  facilitate  retrieval. 
«  D.  CODASYL  Features  Omitted  from  DPBMS 

1.  Unlimited  name  length  -  restricted  to  30  character  maximum. 

2.  .Sub-schema  DDL  may  change  privacy  locks,  reorder  items  -  omitted  to 
Improve  compatibility  of  sub-schema  with  schema. 

3.  KEEP/FREE  DML  Verbs  -  omitted  to  allow  the  system  to  control  record 
access  in  order  to  avoid  deadlock  situations. 

E.  Utilities 

Since  the  CODASYL  specifications  do  not  Include  utilities,  absolute 
comparisons  among  the  network  systems  are  difficult.  However,  DDBMS  has  a 
more  comprehensive  utility  package  than  any  of  the  systems  listed  in  Reference 
l7l. 
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Appendix  A 
Schema  DDL 


Real*  'Section 
REALM  IS  name 


Set  Section 

Set  Description 
Set  IS  name 


MODE  IS  ^CHAIN  {LINKED  TO  PRIOR $ 


ORDER  IS 


POINTER-ARRAY 

FIRST  ^ 
i LAST  ( 
I  NEXT  / 
PRIOR  \ 
IMMATERIAL\ 
* SORTED  J 


J 


WITHIN  RECORD-NAME 

by  Database-key 

DUPLICATES  ARE  C FIRST  ~) 

<  LAST  f 

/not  allowed! 


-55- 


OWNER  IS  record  name 
Member  section  - 

MEMBER  IS  name  C MANDATORY/  f  AUTOMATIC/ 
(^OPTIONAL  J  (  MANUAL  J 


[‘ 


LINKED  TO  OWNER 


3 


(DUPLICATES  ARE  NOT  ALLOWED 
FOR  identifiers 


L 


3 


/"ASCENDING  7 
(descending) 


KEY  IS  identifiers 


E 


DUPLICATES  ARE  (FIRST 
{LAST 


(NOT  ALLOWED 


I 


SET  SELECTION  IS  THRU  f CURRENT  OF  SET  } 

(LOCATION  MODE  OF  OWNER/ 


[USING  identifiers" 


J 


Record  Section 

Record  Description 
RECORD  IS  name 


LOCATION  MODE  IS  DIRECT  dbkay 
^ LOCATION  MODE  IS  CALC  USING  keys 

DUPLICATES  ARE  [NOT]  ALLOWED 
LOCATION  MODE  IS  VIA  setname  SET 
LOCATION  MODE  IS  SYSTEM 


WITHIN  realm 

^PRIVACY  LOCK  [FOR  operations! 


IS  (literal 

1  procedurenameC 


Data  Description 
{level  number] 


character-string 

[binary^  [Fixed!  (Teal  ”1 
JdecxmmJ  [float)  ^complex) 

foT  site 

(Character) 

DATABASE  -  KEY 


[OCCURS  count  time] 

[RANGE  IS  FROM  valuel  TO  value2] 


PRIVACY  LOCK  IS 

for/store^1 

IS  fliteral  ") 

\get  J 

/procedurename) 

^MODIFY 

___ 

L  (°btaiji 

- - 

} 

i 
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Sub-Schema  DDL  Syntax 
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Sub-Schema  Section 


SS  sub-schema  name  WITHIN  schema-name 


Allas  Section 


Set  Section 


SD  fALL 

1 setnamel 


;SET  SELECTION  FOR  recordname  IS 
VIA  setnamel  OWNER  ^SYSTEM  „ 

j CURRENT  ) 
Sldentifierl  .  X 
(VALUE  OF  identifiers!  IS  identifiers] 


[VIA  aetname2  OWNER  VALUE  OF  identifier*  IS  identifier?. 


Record  Section 


01  recordname  (WITHIN  realm] 


mmmgmggm 
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Data  Description 


lavcl  nuaber  datanawel 


(i  PIC  IS  characterstring  1 


[;  (USAGE  IS] 


f  BIT  ^ 

\  COMP 

I  COMP-n 

/  DBKEY 

DISPLAY 

DISPLAY-n 

INDEX 

INDEX-n 

^  J. 

[i  OCCURS  Integer  TIMES] 


ASCENDING  ? 
DESCENDINCJ 


KEY  IS  ^datanames2j 
(INDEXED  BY  Indices  ] 
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APPENDIX  C 
DML  Syntax 


/ 


Data  Division 


INVOKE  sub-schema  OF  SCHEMA  schema 


Procedure  Division 

ACCEPT  identifier! 


FROM 


CURRENCY 


REAL-NAME 


CONNECT  [record]  TO 


DISCONNECT  [record]  FROM  fsets 

(ASST 


ERASE  [record] 


PERMANENT 

SELECTIVE 

ALL 


MEMBERS 


FIND  record  selection  expression 

;  RETAINING  CURRENCY  FOR  [  MULTIPLE') 

REALM  ( 
£ET  > 
sets 
RECORD 


FINISH  realas 


GET  [Identifiers] _ 

MODIFY  ^  [record] 

identifiers 


{ including")  (all  ~i  membership 

(ONLY  j  (sets  ( 

P  INCLUDING  TALL  '/ 

(sets  } 


MEMBERSHIP 

_! 


OBTAIN  record  selection  expression 

RETAINING  CURRENCY  FOR  C MULTIPLE) 

REALM  ( 
i  SET  ) 

sets  1 
RECORD  J 


• — 

- 

N*” 

READY 

realm 

USAGE-MODE  IS 

[exclusive] 

\ RETRIEVAL? 

STORE 

record 

- 

Lprotectedj 

(UPDATE  J 

- 

[7 RETAINING  CURRENCY  FOR  ( MULTIPLE^ 

I  \  REALM  / 

|  /  SET  i 

1  /  sets 

(  RECORD 


L 
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USE 


r-  ^  'T\ 

FOR  PRIVACY 

on  [exclusive!  [retrieval 

FOR  (realms! 

[protected]  (.UPDATE  ) 

(realms) 

Jr  J 

_ 

f CONNECT  ^ 

i  DISCONNECT  / 

\  STORE 
j  ERASE 

{  ERASE  PERMANENT  > 
| ERASE  SELECTIVE 
/ERASE  ALL 
GET 

/  MODIFY 
l  FIND 

(obtain 


(CONNECT 

(find 

( DISCONNECT 
(OBTAIN 


(GET  1 
(  MODIFY/ 
(STORE  j 
(OBTAIN  _t 


There  are  seven  formats  for  record  selection  expression. 


1.  DBKEY  IS  identifier! 


2.  (ANY  7 

(PUPLICATEJ 


recordnamel 


3.  DUPLICATE  WITHIN  set!  USING  identifiers2 
!  frecordname2]  WITHIN 


4.  f NEXT 
PRIOR 
i FIRST 
(LAST 
1  integer 
identifier! 


5.  CURRENT  (recordname2]l WITHIN 


IN  f set2  7 
.  ) realm! i 


fwiTHIN 

(set2  ! 

J  real mil 

L 

L  J 

.  6.  OWNER  WITHIN  set2 
7.  recordname2  WITHIN  set2  (CURRENT]  (USING  identifiers!] 


V  »•  *- 
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APPENDIX  D 
DMCL  Syntax 
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DMCL  Description 

DD  dmclname  FOR  schema 
Buffer  Description 
BD  buffer 

PAGE  SIZE  inteqerl  BYTES 
BUFFER  SIZE  integer2  PAGES 

Realm  Description 

RD  )' realms) 

[ALL  l 

Processor  Description 

BACK  I 
HOSTS 


ND  processor  id 
( processor  ids) 
[ALL  j 
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APPENDIX  E 

Comparison  of  DDBMS 
and  Other  CODASYL  Systems 


t 
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The  comparison  between  DDBHS  and  the  other  CODASYL  data  base  systems 
la  aade  here  using  tables  that  Indicate  the  main  features  of  several  systems . 

The  ays teas  considered  are  DDBMS,  CODASYL  specifications,  DEC's  DBMS-10,  UNIVAC'a 
CMS- 1100 ,  Honeywell's  (Xerox)  EDMS,  and  Culllnane's  IDMS.  The  tables  are  an 
extension  of  those  prepared  by  Warren  [7  ]. 
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